Namespaces
Variants

std::literals::chrono_literals:: operator""s

From cppreference.net
Défini dans l'en-tête <chrono>
constexpr std:: chrono :: seconds
operator "" s ( unsigned long long secs ) ;
(1) (depuis C++14)
constexpr std:: chrono :: duration < /*unspecified*/ >
operator "" s ( long double secs ) ;
(2) (depuis C++14)

Forme un littéral std::chrono::duration représentant des secondes.

1) Littéral entier, retourne exactement std:: chrono :: seconds ( secs ) .
2) Littéral à virgule flottante, retourne une durée à virgule flottante équivalente à std::chrono::seconds .

Table des matières

Paramètres

secs - le nombre de secondes

Valeur de retour

Le littéral std::chrono::duration .

Implémentation possible

constexpr std::chrono::seconds operator""s(unsigned long long s)
{
    return std::chrono::seconds(s);
}
constexpr std::chrono::duration<long double> operator""s(long double s)
{
    return std::chrono::duration<long double>(s);
}

Notes

Cet opérateur est déclaré dans l'espace de noms std :: literals :: chrono_literals , où à la fois literals et chrono_literals sont des espaces de noms inline . L'accès à cet opérateur peut être obtenu avec :

  • using namespace std :: literals ,
  • using namespace std :: chrono_literals , ou
  • using namespace std :: literals :: chrono_literals .

De plus, dans l'espace de noms std :: chrono , la directive using namespace literals :: chrono_literals ; est fournie par la bibliothèque standard , de sorte que si un programmeur utilise using namespace std :: chrono ; pour accéder aux classes de la bibliothèque chrono , les opérateurs littéraux correspondants deviennent également visibles.

std::string définit également operator "" s , pour représenter les objets littéraux de type std::string , mais il s'agit d'un littéral de chaîne : 10s représente dix secondes, tandis que "10" s est une chaîne de deux caractères.

Exemple

#include <chrono>
#include <iostream>
int main()
{
    using namespace std::chrono_literals;
    std::chrono::seconds halfmin = 30s;
    std::cout << "Half a minute is " << halfmin.count() << " seconds"
        " (" << halfmin << ").\n"
        "A minute and a second is " << (1min + 1s).count() << " seconds.\n";
    std::chrono::duration moment = 0.1s;
    std::cout << "A moment is " << moment.count() << " seconds"
        " (" << moment << ").\n"
        "And thrice as much is " << (moment + 0.2s).count() << " seconds.\n";
}

Sortie :

Half a minute is 30 seconds (30s).
A minute and a second is 61 seconds.
A moment is 0.1 seconds (0.1s).
And thrice as much is 0.3 seconds.

Voir aussi

construit une nouvelle durée
(fonction membre publique de std::chrono::duration<Rep,Period> )